## **CLAIMS**

Now, therefore, the following is claimed:

- A computer system for enabling selective execution of sets of code in 1. 1 computer programs, comprising: 2 memory for storing a computer program, said computer program having a set 3 of code and a branch instruction; and 4 5 processing circuitry configured to receive run time data indicating whether said set of code is enabled and to set a value of a mode indicator based on said run 6 7 time data, said processing circuitry configured to receive and execute said branch instruction during a run of said computer program, said processing circuitry 8 9 configured to branch to a first address of said memory, in response to said branch instruction and based on said value of said mode indicator, when said set of code is 10 11 enabled, said processing circuitry further configured to branch to a second address of 12 said memory, in response to said branch instruction and based on said value of said mode indicator, when said set of code is disabled. 13
- 1 2. The system of claim 1, wherein said set of code, when executed by said 2 processing circuitry, tests for errors that occur during said run of said program.

- The system of claim 1, wherein said branch instruction includes a first
- 2 address identifier and a second address identifier, said first address identifier
- 3 identifying said first address and said second address identifier identifying said second
- 4 address, and wherein said processing circuitry further configured to select one of said
- 5 address identifiers based on said value of said mode indicator in response to said
- 6 branch instruction.
- 1 4. The system of claim 1, wherein said processing circuitry is further
- 2 configured to maintain said value of said mode indicator during said run of said
- 3 computer program and until termination of said run.
- The system of claim 1, wherein said processing circuitry executes said
- 2 set of code when said processing circuitry branches to said first address, and wherein
- 3 said processing circuitry executes an instruction at said second address upon
- 4 completing execution of said set of code.
- 1 6. The system of claim 1, wherein said branch instruction includes an
- 2 address identifier that identifies said first address, and wherein an instruction of said
- 3 set of code is stored in said memory at said first address.
- 7. The system of claim 6, wherein said processing circuitry, in executing
- 2 said branch instruction, is configured to identify said second address based on said
- 3 first address when said set of code is disabled.

- 1 8. The system of claim 6, wherein said processing circuitry, in executing 2 said branch instruction, is configured to flip a bit of said first address when said set of 3 code is disabled.
- 9. The system of claim 1, wherein said branch instruction includes an address identifier that identifies said second address, and wherein an instruction of said set of code is stored in said memory at said first address.
- 1 10. The system of claim 9, wherein said processing circuitry, in executing said branch instruction, is configured to identify said first address based on said second address when said set of code is enabled.
- 1 11. The system of claim 9, wherein said processing circuitry, in executing said branch instruction, is configured to flip a bit of said second address when said set of code is enabled.
- 1 12. The system of claim 1, wherein said branch instruction includes an 2 address identifier identifying one of said addresses.

- The system of claim 12, wherein said branch instruction is encoded 1 13. 2 with an expression, and wherein said processing circuitry is further configured to compute a new address for each branch instruction that is encoded with said 3 expression and that is executed by said processing circuitry during said run of said 4 computer program, said new address based on an address identifier included in said 5 each branch instruction. 6 14. A system for enabling selective execution of sets of code in computer 1 2 programs, comprising: means storing a computer program, said computer program having a set of 3 code and a branch instruction, said branch instruction including an address identifier 4 identifying a first memory address; 5 means for receiving, during a run of said program, run time data indicating 6 7 whether said set of code is enabled; means for setting a value of a mode indicator based on said run time data; 8 9 means for identifying a second memory address in response to said branch
- 9 means for identifying a second memory address in response to said branch 10 instruction; and
- means for branching to said second address based on said value of said mode indicator and said identified memory address, said branching means including a means for executing an instruction at said second address.

15. A method for enabling selective execution of sets of code in computer 1 programs, comprising the steps of: 2 storing a computer program in memory, said computer program having a set of 3 code and a branch instruction, said branch instruction including an address identifier 4 identifying a first address in said memory; 5 receiving, during a run of said program, run time data indicating whether said 6 set of code is enabled; 7 setting a value of a mode indicator based on said run time data; 8 identifying a second address in said memory and in response to said branch 9 instruction; 10 branching to said second address based on said value of said identifying step 11 and said value of said mode indicator; and 12 executing an instruction at said second address in response to said branching 13 14 step. 16. The method of claim 15, wherein said identifying step includes the step 1 2 of flipping a bit of a bit value representing said first address. 17. The method of claim 15, further comprising the step of maintaining 1 2 said value of said mode indicator during said run of said computer program and until

21

termination of said run.

3

The method of claim 15, wherein said branch instruction includes an 18. 1 address identifier identifying said second address, said identifying step including the 2 step of selecting said second address identifier based on said value of said mode 3

indicator.

4

6

- The method of claim 15, wherein said branch instruction is encoded 1 with an expression, and wherein said method further includes the step of: 2 computing a new address for each branch instruction from said computer 3 program that is encoded with said expression and that is executed during said run of 4
- said program, said new address based on an address identifier included in said each 5 branch instruction.
- The method of claim 15, wherein said instruction executed in said 20. 1 2 executing step is outside of said set of code, and wherein said branching step prevents 3 execution of said set of code, said value of said mode indicator indicating that said set of instructions is disabled. 4
- 21. 1 The method of claim 15, wherein said instruction executed in said 2 executing step is included in said set of code, said value of said mode indicator indicating that said set of instructions is enabled. 3
- 22. The method of claim 21, further comprising the step of testing, in 1 response to said set of code, for errors generated by said program run. 2